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IN THE CLAIMS: 

Please cancel Claims 75-76 without prejudice, and amend Claims 24, 33, 42, 51, 60, 69 
and 74 as follows: 



IV23. (cancelled) 

24. (ourently amended) A method for programming a programmable system 
comprising a fixtaxl processor portion and a user programmable address arithmetic unit, the 
method comprising^ 

writing a first program in a first programming language, said first program configured to 
implement one or more us^-defined address calculation functions in said programmable address 
arithmetic unit; \ 

compiling said first prograr^i 

generating a first executable imhge, said first executable image adapted for loading into a 
first program memory coupled to said programmable address arithmetic unit; 

/writing a second program in a second programming language, said second program 
configured to implement a desired algorithm, wherein the second programming language consists 
ef comprises a fixed set instructions that make use ofva fixed set of addressing modes, wherein at 
least one of the addressing modes comprises a user defined addressing mode; 

compiling said second program into object code, saidvobject code comprising a plurality 
of machine level instructions drawn from the fixed instruction sk of for the processor, said 
plurality of machine level instructions comprising at least one instruction to control said 
programmabl e addr e ss arithm e tic unit that invokes the user defined adasessing mode; and 

generating a second executable image, said second executable imagesadapted for loading 
into a second program memory coupled to said processor. \ 
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25. (previously presented) The method of Claim 24, wherein said address calculation 
function is\nvoked by an auto-update addressing mode. 

26. (previously presented) The method of Claim 24, wherein said first programming 
language is a hardware definition language. 

27. (previously presented) The method of Claim 26, wherein said second 
programming language is an assembly language. 

28. (previously presented) The method of Claim 26, wherein said second 
programming language isV high level programming language. 

29. (previously presented) The method of Claim 24, wherein said address arithmetic 
unit provides special purpose circuitry, said method further comprising the step of adapting said 
first program to use a software liVary to access said special purpose circuitry. 

30. -32. (cancelled) \ 

33. (currently amended) X method of supplying software, comprising: 

supplying a first software moduleVomprising instructions drawn from a fixed set of 
instructions to implement an algorithm usiirfe a processor having a fixed portion and a 
programmable addressing arithmetic unit fPAMJ); and 

supplying a second software module comprising configuration codes to define the 
operation of a user-defined addressing mode to be executed in the PAAU; a programmable 
addressing arithm e tic unit (PAAU) ; \ 

wh e r e by wherein at least one instruction in said first module references an operand using 
said user-defined addressing mode. \ 

34. (previously presented) The method of Claim 33, Vhereby at least some of said 
instructions in said first software module are used to program a digital signal processor. 

35. (previously presented) The method of Claim 33, whereby said at least one 
instruction causes an auto-update to be applied to a pointer operand, the operation of the auto- 
update being defined at least in part by said user-defined addressing mode. \ 
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y 56. (previously presented) The method of Claim 35, further comprising specifying 
said auto-ubdate using an assembly language mnemonic. 

37. (previously presented) The method of Claim 36, whereby said first software 
module comprises a second instruction, said second instruction being used to specify one of a 
plurality of user-deftned addressing modes to be selected to define, at least in part, the operation 
of said auto-update. \ 

38. (previously presented) The method of Claim 33, further comprising configuring a 
programmable logic block wrthin said PAAU using at least a portion of said configuration codes 
in said second software moduleX 

39. (previously presented) \ The method of Claim 33, further comprising programming 
a set of sequential logic operations as implemented by a microsequenced state machine within 
said PAAU using at least a portion of saiX configuration codes in said second software module. 

40. (previously presented) The method of Claim 33, further comprising programming 
a crossbar switching element within said PAAUoising at least one of said configuration codes in 
said second software module. \ 

41 . (previously presented) The method of GJaim 33, whereby said first software 
module comprises a plurality of subsets of instructions, each subset of instructions to be 
dispatched to one of a plurality of functional units in a mulVissue processor, the method further 
comprising dispatching at least one of said subsets to a functional unit comprising said PAAU. 

42. (currently amended) A computer-readable mediufcn containing a first software 
module having a sequence of instruction drawn from a fixed set of instructions to implement an 
algorithm using a processor having a fixed portion and a programmableyaddressing arithmetic 
unit (PAAU) , and a second software module containing configuration coa^s which define the 
operation of a user-defined addressing mode, said first and second modules implementing the 
method of: \ 

executing said instructions in said first software module to implement said algorithm; and 
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sing said configuration codes to configure the operation of said user-defined addressing 
mode to bV executed in the PAAU ; 

wh e reby wherein at least one instruction in said first module references an operand using 
said user-defined addressing mode. 

43. (previously presented) The medium of Claim 42, whereby at least some of said 
instructions in said\rst software module are used to program a digital signal processor. 

44. (previously Vesented) The medium of Claim 42, whereby said at least one 
instruction causes an autoWdate to be applied to a pointer operand, and the operation of the 
auto-update is defined by sard user-defined addressing mode. 

45. (previously presented) The medium of Claim 44, whereby an assembly language 
mnemonic is used to specify said auto-update. 

46. (previously presented) \The medium of Claim 45, whereby said first software 
module comprises a second instruction^ said second instruction specifying one of a plurality of 
user-defined addressing modes to be selected to define the operation of said auto-update. 

47. (previously presented) The medium of Claim 42, whereby at least some of said 
configuration codes in said second software module are used to configure a programmable logic 
block within said PAAU. 

48. (previously presented) The medium ofClaim 42, whereby at least some of said 
configuration codes in said second software module arVused to program a set of sequential logic 
operations as implemented by a microsequenced state machine within said PAAU. 

49. (previously presented) The medium of Claim ^2, whereby said configuration 
codes in said second software module are used to program a crossbar switching element within 
said PAAU. \ 

50. (previously presented) The medium of Claim 42, whe^by said first software 
module comprises a plurality of subsets of instructions, each subset of instructions to be 
dispatched to one of a plurality of functional units in a multi-issue processor whereby one of said 
subsets is dispatched to a functional unit comprising said PAAU. 
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51 .^currently amended) A method of executing software in a computerized system, 
said system comprising a proc e ssor with a fixed processor portion and a programmable 
addressing uni™PAAU), a first software module containing a sequence of instructions drawn 
from a fixed set of instructions to implement an algorithm using a processor having a fixed 
portion and the PAAU, instructions d e fining th e op e ration of an algorithm and a second software 
module containing configuration codes defining the operation of a user-defined addressing mode 
supplied by said PAAlAthe method comprising: 

executing instructions in said first software module to implement sakl an algorithm; and 

using said configuration codes to configure the operation of said user-defined addressing 
mode to be executed in the PAAU ; 

whereby at least one instruction in said first module references an operand using said 
user-defined addressing mode. \ 

52. (previously presented) The method of Claim 51, further comprising using at least 
some of said instructions in said first software module to program a digital signal processor. 

53. (previously presented) The method of Claim 51, further comprising: 

defining the operation of the auto-update by said user-defined addressing mode; and 

causing an auto-update to be applied to a, pointer operand using said at least one 
instruction. \ 

54. (previously presented) The method orClaim 53, further comprising said auto- 
update using an assembly language mnemonic. \ 

55. (previously presented) The method of Claim 54, whereby said first software 
module comprises a second instruction, and said method further comprises specifying one of a 
plurality of user-defined addressing modes to be selected to define the operation of said auto- 
update using said second instruction. \ 

56. (previously presented) The method of Claim 51, furtner comprising using at least 
some of said configuration codes in said second software module to configure a programmable 
logic block within said PAAU. \ 
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<\ 

Stf . (previously presented) The method of Claim 5 1 , further comprising using at least 
some of said configuration codes in said second software module to program a set of sequential 
logic operatic^sas implemented by a microsequenced state machine within said PAAU. 

58. (previously presented) The method of Claim 51, further comprising using said 
configuration codes\in said second software module to program a crossbar switching element 
within said PAAU. 

59. (previously presented) The method of Claim 51, whereby said first software 
module comprises a plurality of subsets of instructions, each subset of instructions to be 
dispatched to one of a pluralit\of functional units in a multi-issue processor, the method further 
comprising dispatching at least one of said subsets to a functional unit comprising said PAAU. 

60. (currently amended) \ A computerized system adapted for loading a first software 
module having a plurality of instructions drawn from a fixed instruction set and a second 
software module having at least one configuration code, the system comprising: 

a processor having a fixed portion an^ a programmable addressing arithmetic unit 
(PAAU); 

wh e r e by wherein said processor is adapted^o: 

(i) execute at least a first one of said plurhjity of instructions to at least partially 
implement an algorithm, 

(ii) configure a user-defined addressing mode ii\said PAAU using said at least one 
configuration code, and 

(iii) execute at least a second one of said plurality of irktructions, said at least second 
instruction referencing an operand using said user-defined addressing mode , said 
second instruction also being executed to at least partiaUy implement said 
algorithm . 

61 . (previously presented) The system of Claim 60, whereby at le^$t some of said 
instructions in said first software module are used to program a digital signal processor. 
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6^. (previously presented) The system of Claim 60, whereby said at least one 
instruction csauses an auto-update to be applied to a pointer operand, and the operation of the 
auto-update ikdefined by said user-defined addressing mode. 

63. (previously presented) The system of Claim 62, whereby an assembly language 
mnemonic is usea\to specify said auto-update. 

64. (previously presented) The system of Claim 63, whereby said first software 
module comprises a second instruction, said second instruction specifying one of a plurality of 
user-defined addressing modes to be selected to define the operation of said auto-update. 

65. (previously preseWd) The system of Claim 60, whereby at least some of said 
configuration codes in said second software module are used to configure a programmable logic 
block within said PAAU. \ 

66. (previously presented) \ The system of Claim 60, whereby at least some of said 
configuration codes in said second sorhvare module are used to program a set of sequential logic 
operations as implemented by a microsequenced state machine within said PAAU. 

67. (previously presented) The system of Claim 60, whereby said configuration codes 
in said second software module are used to program a crossbar switching element within said 
PAAU. \ 

68. (previously presented) The system of Claim 60, whereby said first software 
module comprises a plurality of subsets of instructions, each subset of instructions to be 
dispatched to one of a plurality of functional units in a multi-issue processor, whereby one of said 
subsets is dispatched to a functional unit comprising said i?AAU. 

69. (currently amended) A computer-implementfed method for programming a 
processor comprising a programmable addressing arithmetic umt (PAAU), the method 
comprising: \ 

allowing a sequence of instructions defining a program for implementing an algorithm to 
execute, thereby generating a sequence of addresses; \ 

observing at least a subsequence of said sequence of addresses; and \ 



AppK No. : 09/685,272 

Filed : October 9, 2000 

derating a configuration program for said PAAU, said configuration program defining a 
user-defined auto-update addressing mode, wh e r e by wherein successive executions of said user- 
defined autoAupdate addressing mode is capabl e of r e g e n e rating operative to regenerate said 
subsequence. \ 

70. (previously presented) The method of Claim 69, whereby said act of observing 
comprises observing a subsequence that corresponds to an address history sequence of a pointer 
variable. \ 

71 . (previously presented) The method of Claim 70, further comprising defining an 
auto-update operation using, said user-defined addressing mode, said auto-update defining at 
least one method for advancing from a current address element of said subsequence to a 
successive address-element of skid subsequence. 

modifying said sequence of instructions by inserting into at least a subset of specified 
instructions a mnemonic that specifies said auto-update operation, such that when said modified 
sequence of instructions is executed, said\ointer undergoes said observed subsequence of 
addresses. \ 

73. (previously presented) The method of Claim 72, further comprising executing said 
sequence of instructions in N cycles and said modified set of instructions in M cycles, with the 
value of M being less than that of N. \ 

74. (currently amended) A method of executing software in a computerized system, 
said system comprising a means for processing digital dat^. said means for processing 
comprising a fixed processor portion and programmable means for addressing, a first software 
module containing instructions defining the operation of an algorithm and a second software 
module containing configuration codes defining the operation of asuser-defined addressing mode 
supplied by said means for addressing, the method comprising the steps of: 

executing instructions in a the first software module for implementing said algorithm,, 
wherein the instructions are drawn from a fixed instruction set ; and \ 
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us\ng said configuration codes fer to configure the operation of said user-defined 
addressing mode; 

wh e r e by wherein at least one instruction in said first module is used for referencing an 
operand, said referencing of said operand being accomplished at least in part with said user- 
defined addressingonode. 

75.-76. (canceled) 

Please add new claims 77-79 as follows: 

77. (new) For use with a processor having a fixed architecture portion and a 
programmable address arithmetic unit (PAAU), a method of executing an algorithm by executing 
a sequence of opcodes assembled based upon an assembly language having a fixed instruction set 
and at least one mnemonic that refers to an operand in memory according to a user-defined 
addressing mode, the method comprising: 

writing a set of configuration codes into a storage area to define a first operation and a 
second operation of the user-defined addressing mode; 

executing a first instruction that invokes, the user-defined addressing mode and 
calculating a first operand address using the first operation of the user-defined addressing mode; 

executing a user-defined addressing mode change instruction that causes the second user- 
defined addressing mode to be activated into a PAAU; and 

executing a second instruction that invokes the user-Hefined addressing mode and 
calculating a second operand address using the second operation of the user-defined addressing 
mode. 

78. (new) The method of Claim 77, wherein the user-defined addressing mode 
change instruction further causes the first user-defined addressing modes^o be deactivated. 

79. (new) A computerized system comprising: 

a processor comprising a fixed architecture portion and a programmabl\address 
arithmetic unit (PAAU); 
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a fKst software module comprising a collection of opcodes assembled from a fixed 
assembly langvmge that has a fixed set of instructions, a fixed set of fixed addressing modes, and 
at least one user-defined auto-update addressing mode, wherein the execution of the first 
software module resuKs in the implement an application algorithm through a sequence of 
individual op-code executions defined by a program flow; and 

a configuration data mooaje comprising at least one configuration code adapted to 
configure the operation of at least oneH^ser-defined auto-update addressing mode in the PAAU; 

wherein at least a subsequence of the^s^quence of individual op-code executions makes 
reference to an operand using the user-defined autbxupdate addressing mode, and the execution 
of successive instructions in the subsequence of instruokms results in a addressing pattern to be 
generated, wherein the addressing pattern is nonlinear and is aqnendent on the application 
algorithm, and wherein the user-defined auto-update addressing mbcte is configured to generate 
the addressing pattern using less instruction cycles than would be possiote^by using a 
combination of instructions involving the fixed set of addressing modes. 



